package com.qianfeng.mybatis.mapper;

//
//                            _ooOoo_  
//                           o8888888o  
//                           88" . "88  
//                           (| -_- |)  
//                            O\ = /O  
//                        ____/`---'\____  
//                      .   ' \\| |// `.  
//                       / \\||| : |||// \  
//                     / _||||| -:- |||||- \  
//                       | | \\\ - /// | |  
//                     | \_| ''\---/'' | |  
//                      \ .-\__ `-` ___/-. /  
//                   ___`. .' /--.--\ `. . __  
//                ."" '< `.___\_<|>_/___.' >'"".  
//               | | : `- \`.;`\ _ /`;.`/ - ` : | |  
//                 \ \ `-. \_ __\ /__ _/ .-` / /  
//         ======`-.____`-.___\_____/___.-`____.-'======  
//                            `=---='  
//  
//         .............................................  
//                  佛祖镇楼                  BUG辟易  
//          佛曰:  
//                  写字楼里写字间，写字间里程序员；  
//                  程序人员写程序，又拿程序换酒钱。  
//                  酒醒只在网上坐，酒醉还来网下眠；  
//                  酒醉酒醒日复日，网上网下年复年。  
//                  但愿老死电脑间，不愿鞠躬老板前；  
//                  奔驰宝马贵者趣，公交自行程序员。  
//                  别人笑我忒疯癫，我笑自己命太贱；  
//  


import com.qianfeng.mybatis.pojo.Category;
import org.apache.ibatis.annotations.Param;
import org.apache.ibatis.annotations.ResultMap;
import org.apache.ibatis.annotations.Select;

import java.util.List;

/**
 * Created by Jackiechan on 2021/12/8/20:58
 *
 * @author Jackiechan
 * @version 1.0
 * @since 1.0
 */
public interface CategoryMapper {
    @Select("select * from categories where id = #{id}")
    Category findById(Long id);

    @ResultMap("cte") //指定使用那个resultmap,resultmap只能在xml文件中声明
    @Select("select ds.*,cy.id cid,cy.categoryname,cy.txcommand,cy.rxcommand,cy.commandname,cy.status cstatus         from categories cy left join devices ds on cy.id = ds.categoryid where cy.id = #{cyid}")
    Category findByIdWithDevice(Long id);


    @ResultMap("cte")
    @Select("<script> select ds.*,cy.id cid,cy.categoryname,cy.txcommand,cy.rxcommand,cy.commandname,cy.status cstatus from categories\n" +
            "        cy left join devices ds on cy.id = ds.categoryid\n" +
            "\n" +
            "        <where>\n" +
            "            <if test=\"id !=null\">\n" +
            "              and  cy.id=#{id}\n" +
            "            </if>\n" +
            "            <if test=\"status !=null\">\n" +
            "                and  cy.status=#{status}\n" +
            "            </if>\n" +
            "        </where></script>")
    List<Category> findByIdOrStatus(@Param("id") Long id, @Param("status") Long status);
}
